$value) { if (self::isRectorClassValue($key)) { if (\class_exists($key)) { $skippedRectorRules[] = $key; } else { $nonExistingRules[] = $key; } continue; } if (!self::isRectorClassValue($value)) { continue; } if (\class_exists($value)) { $skippedRectorRules[] = $value; continue; } $nonExistingRules[] = $value; } SimpleParameterProvider::addParameter(Option::SKIPPED_RECTOR_RULES, $skippedRectorRules); if ($nonExistingRules === []) { return; } $nonExistingRulesString = ''; foreach ($nonExistingRules as $nonExistingRule) { $nonExistingRulesString .= ' * ' . $nonExistingRule . \PHP_EOL; } throw new ShouldNotHappenException('These rules from "$rectorConfig->skip()" does not exist - remove them or fix their names:' . \PHP_EOL . $nonExistingRulesString); } /** * @param mixed $value */ private static function isRectorClassValue($value) : bool { // only validate string if (!\is_string($value)) { return \false; } // not regex path if (\strpos($value, '*') !== \false) { return \false; } // not if no Rector suffix if (\substr_compare($value, 'Rector', -\strlen('Rector')) !== 0) { return \false; } // not directory if (\is_dir($value)) { return \false; } // not file return !\is_file($value); } /** * @param string[] $values * @return string[] */ private static function resolveDuplicatedValues(array $values) : array { $counted = \array_count_values($values); $duplicates = []; foreach ($counted as $value => $count) { if ($count > 1) { $duplicates[] = $value; } } return \array_unique($duplicates); } }